### Bài 7: UART Software & UART Hardware

# 7.1 Phần Cứng USART



Bảng chân kết nối ra GPIO của USART1.

| D9  | D11 | 29 | D7 | 41 | 67 | 20 | PA8  | I/O | FT | PA8  | USART1_CK/<br>TIM1_CH1 <sup>(9)</sup> /<br>MCO                             | - |
|-----|-----|----|----|----|----|----|------|-----|----|------|----------------------------------------------------------------------------|---|
| С9  | D10 | 30 | C7 | 42 | 68 | 21 | PA9  | I/O | FT | PA9  | USART1_TX <sup>(9)</sup> /<br>TIM1_CH2 <sup>(9)</sup>                      | - |
| D10 | C12 | 31 | C6 | 43 | 69 | 22 | PA10 | I/O | FT | PA10 | USART1_RX <sup>(9)</sup> /<br>TIM1_CH3 <sup>(9)</sup>                      | - |
| C10 | B12 | 32 | C8 | 44 | 70 | 23 | PA11 | I/O | FT | PA11 | USART1_CTS/<br>CANRX <sup>(9)</sup> /<br>USBDM/<br>TIM1_CH4 <sup>(9)</sup> | - |
| B10 | A12 | 33 | B8 | 45 | 71 | 24 | PA12 | I/O | FT | PA12 | USART1_RTS/<br>CANTX <sup>(9)</sup><br>/USBDP<br>TIM1_ETR <sup>(9)</sup>   | - |

# 7.1.2 Các Thanh Ghi của USART

Table 198. USART register map and reset values

| Mathematical Register   Math |        |             |          |                     | _  | _  | _  |    | _  | _  | _    |      |    | _  | _        | _     |      |       |      |        | _    | . •  |        |          |     |      |       |      |        |        |    |   |     |     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------|----------|---------------------|----|----|----|----|----|----|------|------|----|----|----------|-------|------|-------|------|--------|------|------|--------|----------|-----|------|-------|------|--------|--------|----|---|-----|-----|
| Reserved   Reserved  | Offset | Register    | 31       | 30                  | 29 | 28 | 27 | 56 | 25 | 24 | 23   | 22   | 21 | 20 | 19       | 18    | 41   | 16    | 15   | 14     | 13   | 12   | 11     | 10       | 6   | œ    | 7     | 9    | 5      | 4      | က  | 2 | 1   | 0   |
| USART_DR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0x00   | _           | Reserved |                     |    |    |    |    |    |    |      |      |    |    |          |       |      | TXE   | 70   |        |      |      |        |          |     |      |       |      |        |        |    |   |     |     |
| Note   Heserved   DIV_Mantissa[15:4]   Signal   Heserved   Hese |        | Reset value |          |                     |    |    |    |    |    |    |      |      |    |    |          |       |      |       |      |        |      |      |        |          | 0   | 0    | 1     | 1    | 0      | 0      | 0  | 0 | 0   | 0   |
| USART_BRR   Reserved   DIV_Mantissa[15:4]   DIV_Fraction [3:0]   DIV_F | 0x04   | USART_DR    |          | Reserved            |    |    |    |    |    |    |      |      |    |    |          |       |      |       |      |        | D    | R[8  | :0]    |          |     |      |       |      |        |        |    |   |     |     |
| Note    |        | Reset value |          |                     |    |    |    |    |    |    |      |      |    |    |          |       |      |       |      |        |      |      |        |          |     | 0    | 0     | 0    | 0      | 0      | 0  | 0 | 0   | 0   |
| 0x0C         USART_CR1         Reserved         D         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W         W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0x08   | USART_BRR   |          | Reserved DIV_Mantis |    |    |    |    |    |    |      |      |    |    |          |       |      | tissa | a[15 | :4]    |      |      | •      |          |     |      |       |      |        |        |    |   |     |     |
| Note    |        | Reset value | 1        |                     |    |    |    |    |    |    |      |      |    |    |          |       |      |       | 0    | 0      | 0    | 0    | 0      | 0        | 0   | 0    | 0     | 0    | 0      | 0      | 0  | 0 | 0   | 0   |
| USART_CR2   Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0x0C   | USART_CR1   |          |                     |    |    |    |    |    | F  | lese | erve | d  |    |          |       |      |       |      |        | UE   | Σ    | WAKE   | PCE      | PS  | PEIE | TXEIE | TCIE | RXNEIE | IDLEIE | TE | Æ | RWU | SBK |
| Reset value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        | Reset value | 1        |                     |    |    |    |    |    |    |      |      |    |    |          |       |      |       |      |        | 0    |      | 1      | 0        | 0   | 0    | 0     | 0    | 0      | 0      | 0  | 0 | 0   | 0   |
| 0x14         USART_CR3         Reserved         Image: Control of the contro                                                 | 0x10   | USART_CR2   |          | Reserved ST P       |    |    |    |    |    |    |      |      |    |    | O<br>:0] | CLKEN | CPOL | СРНА  | LBCL | served |      | LBDL | served | ,        | ADD | [3:0 | ]     |      |        |        |    |   |     |     |
| Reset value                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        | Reset value |          |                     |    |    |    |    |    |    |      |      |    |    |          |       |      |       |      | 0      | 0    | 0    | 0      | 0        | 0   | 0    | æ     | 0    | 0      | Re     | 0  | 0 | 0   | 0   |
| 0x18 USART_GTPR Reserved GT[7:0] PSC[7:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0x14   |             |          | Reserved            |    |    |    |    |    |    |      |      |    |    |          |       |      | CTSE  | RTSE | DMAT   | DMAR |      | NACK   |          |     |      |       |      |        |        |    |   |     |     |
| 0x18 Heserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        | Reset value | 1        |                     |    |    |    |    |    |    |      |      |    |    |          |       |      |       |      |        |      |      |        | 0        | 0   | 0    | 0     | 0    | 0      | 0      | 0  | 0 | 0   | 0   |
| Reset value 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0x18   | USART_GTPR  |          | Reserved            |    |    |    |    |    |    |      |      |    |    | GT[7:0]  |       |      |       |      |        |      |      |        | PSC[7:0] |     |      |       |      |        |        |    |   |     |     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        | Reset value |          |                     |    |    |    |    |    |    |      |      |    |    |          |       |      |       | 0    | 0      | 0    | 0    | 0      | 0        | 0   | 0    | 0     | 0    | 0      | 0      | 0  | 0 | 0   | 0   |

CP2102: USART To USB



USART (Universal Synchronous/Asynchronous Receiver/Transmitter) trong các vi điều khiển thường bao gồm nhiều thanh ghi khác nhau để điều khiển hoạt động của module này. Dưới đây là sự khác nhau giữa các thanh ghi bạn đã đề cập:

- 1. **USART\_SR** (**Status Register**): Đây là thanh ghi trạng thái. Nó lưu trữ thông tin về trạng thái hiện tại của USART như các lỗi, cờ trạng thái gửi nhận, v.v. Một số cờ tiêu biểu trong thanh ghi này là:
  - o TXE: Trạng thái bộ đệm truyền dữ liệu.
  - o RXNE: Trạng thái bộ đệm nhận dữ liệu.
  - o TC: Hoàn thành truyền dữ liệu.
- 2. **USART\_DR** (**Data Register**): Đây là thanh ghi dữ liệu. Dữ liệu sẽ được truyền đi hoặc nhận về thông qua thanh ghi này. Khi bạn gửi dữ liệu, bạn viết vào thanh ghi này. Khi bạn nhận dữ liệu, bạn đọc từ thanh ghi này.
- 3. **USART\_BRR** (**Baud Rate Register**): Thanh ghi này được sử dụng để thiết lập tốc độ baud (baud rate) của USART. Tốc độ baud xác định tốc độ truyền dữ liệu giữa vi điều khiển và thiết bi ngoại vi.
- 4. **USART\_CR** (**Control Register**): Đây là các thanh ghi điều khiển. Tùy thuộc vào vi điều khiển cụ thể, có thể có nhiều thanh ghi điều khiển như CR1, CR2, CR3, v.v. Các thanh ghi này chứa các bit điều khiển để bật/tắt USART, thiết lập chế độ truyền, điều chỉnh giao thức, v.v.
- 5. **USART\_GTPR** (**Guard Time and Prescaler Register**): Thanh ghi này được sử dụng để thiết lập thời gian bảo vệ và bộ chia tần số. Thời gian bảo vệ có thể hữu ích trong các ứng dụng cần thời gian bảo vệ giữa các byte dữ liệu.

6. Làm thế nào để sử dụng các thanh ghi

```
7. #include "stm32f4xx.h" // Thư viện tiêu chuẩn của STM32F4
8.
9. void USART2_Init(void) {
10. // 1. Bât clock cho USART2 và GPIOA
11.
     RCC->APB1ENR |= RCC_APB1ENR_USART2EN;
12.
     RCC->AHB1ENR |= RCC_AHB1ENR_GPIOAEN;
13.
14. // 2. Cấu hình chân PA2 và PA3 cho USART2
15. GPIOA->MODER = (2 << (2 * 2)) | (2 << (3 * 2)); // Chọn chế độ alternate
16. GPIOA->AFR[0] = (7 << (2 * 4)) | (7 << (3 * 4)); // Chon alternate function cho
  PA2, PA3 là USART2
17.
18.
    // 3. Cấu hình Baud rate
     USART2->BRR = 0x0683; // 9600 baud rate với clock 16 MHz
19.
20.
21.
     // 4. Bật USART và cấu hình các thông số truyền nhận
     USART2->CR1 |= USART_CR1_TE | USART_CR1_RE; // Bật truyền và nhận
22.
23.
     USART2->CR1 |= USART CR1 UE; // Bât USART
24. }
25.
26. void USART2_Write(int ch) {
27. // Đợi cho đến khi TXE (Transmit Data Register Empty) được set
28.
     while(!(USART2->SR & USART_SR_TXE)) {}
29. USART2-DR = (ch \& 0xFF);
```

```
30. }
31.
32. int USART2 Read(void) {
     // Đơi cho đến khi RXNE (Read Data Register Not Empty) được set
34.
     while(!(USART2->SR & USART SR RXNE)) {}
35.
     return USART2->DR & 0xFF:
36. }
37.
38. int main(void) {
39.
     USART2 Init(); // Khởi tao USART2
40.
41.
     while(1) {
42.
        USART2 Write('H'); // Gửi ký tư 'H'
43.
        for(int i = 0; i < 1000000; i++) {} // Đơi một chút
44.
45. }
46.
```

# 7.1.3.Cách USART Truyền Thông

USART (Universal Synchronous and Asynchronous Receiver-Transmitter) truyền và nhận dữ liệu qua các bước sau:

# 1. Truyền dữ liệu:

- Dữ liệu từ vi điều khiển được đưa vào bộ đệm truyền (transmit buffer) của USART.
- Bô đêm truyền chuyển đổi dữ liêu song song thành dữ liêu nối tiếp.
- o Dữ liêu nối tiếp được gửi ra ngoài qua chân truyền dữ liêu (Tx).

#### 2. Nhân dữ liêu:

- o Dữ liêu nối tiếp từ thiết bị gửi được nhân qua chân nhân dữ liêu (Rx).
- o Bộ đệm nhận của USART chuyển đổi dữ liệu nối tiếp thành dữ liệu song song.
- Dữ liêu song song sau đó được truyền đến vi điều khiển để xử lý.

### 3. Đồng bộ hóa dữ liệu:

- Để xác định được đầu và cuối của một gói dữ liệu, USART sử dụng các bit start và stop.
- o Bit start (bit bắt đầu) báo hiệu sự bắt đầu của một gói dữ liệu.
- o Bit stop (bit kết thúc) báo hiệu sự kết thúc của gói dữ liệu.

#### 4. Điều khiển tốc đô:

- USART có thể hoạt động ở nhiều tốc độ baud khác nhau. chẳng hạn như
   9600, 19200, 38400, 57600, 115200 baud
- Tốc độ baud là số bit truyền trong một giây.

# 5. Uart truyền dữ liệu nối tiếp, theo 1 trong 3 chế độ:

- Simplex: Chỉ tiến hành giao tiếp một chiều
- Half duplex: Dữ liệu sẽ đi theo một hướng tại 1 thời điểm
- Full duplex: Thực hiện giao tiếp đồng thời đến và đi từ mỗi master và slave
- 6. Chân Tx (truyền) của một chip sẽ kết nối trực tiếp với chân Rx (nhận) của chip khác và ngược lại. Quá trình truyền dữ liệu thường sẽ diễn ra ở 3.3V hoặc 5V. Uart là một

giao thức giao tiếp giữa một master và một slave. Trong đó 1 thiết bị được thiết lập để tiến hành giao tiếp với chỉ duy nhất 1 thiết bị khác.

# USART khởi tạo truyền dữ liệu và kết thúc truyền dữ liệu qua các bước sau:

## 1. Khởi tạo truyền dữ liệu:

- Ở trạng thái Idle set đường tín hiệu luôn ở mức cao (hoặc thấp)
- **Kích hoạt USART**: Trước khi bắt đầu truyền dữ liệu, bạn cần kích hoạt bộ USART và cấu hình các tham số như tốc độ baud, số bit dữ liệu, bit kiểm tra chẵn lẻ (parity bit), và số bit dừng.
- Viết vào bộ đệm truyền (Transmit Buffer): Dữ liệu cần truyền được ghi vào bộ đêm truyền của USART.
- **Gửi bit start**: USART tự động thêm một bit start vào trước dữ liệu để báo hiệu bắt đầu truyền dữ liệu.
- **Gửi dữ liệu**: USART bắt đầu truyền từng bit dữ liệu, từ LSB (Least Significant Bit) đến MSB (Most Significant Bit).

## 2. Kết thúc truyền dữ liệu:

- **Gửi bit stop**: Sau khi dữ liệu được truyền hoàn tất, USART tự động thêm một hoặc nhiều bit stop để báo hiệu kết thúc truyền dữ liệu.
- **Xác nhận dữ liệu truyền xong**: Sau khi bit stop được gửi đi, USART báo hiệu rằng quá trình truyền dữ liệu đã hoàn thành và sẵn sàng truyền dữ liệu tiếp theo.



### 7.2. Cấu hình USART Software

UART chỉ sử dụng 2 chân để truyền, đó là TX và RX.



Xác định các chân sử dụng cho UART là bước đầu tiên. UART soft không yêu cầu các chân cụ thể nên ta có thể sử dụng chân bất kì:



## 7.2.1 Xác định thời gian truyền 1 bit => cấu hình timer



Tốc độ baudrate được xác định bởi thời gian truyền đi 1 bit. Ở bài này ta dùng tốc độ phổ thông 9600, ứng với mỗi bit là 105us => xây hàm delay 105us truyền 1 bit.

Timer hoạt động tần số 72MHz=> 1 xung clock = 1/72 us => chọn thang đếm Prescaler = 72-1 => cứ 1 us thì timer đếm lên 1 lần.

## 7.2.2 Chế độ nghỉ (Không truyền), đường TX sẽ được giữ ở mức cao. hàm

UART\_Config() thiết lập chế độ nghỉ cho đường truyền:

```
void UART_Config(){
         GPIO_SetBits(UART_GPIO, TX_Pin);
         delay_us(1);
}
```

## 7.2.3 Hàm truyền:

Hàm truyền sẽ truyền lần lượt 8 bit trong byte dữ liệu, sau khi tín hiệu start được gửi đi.

- Tạo start, delay 1 period time.
  - O Truyền bit dữ liệu. mỗi bi truyền trong 1 period time.
  - O Dich 1 bit.
- Tạo stop, delay tương ứng với số bit stop



```
void UART_Transmit(const char DataValue)
```

```
{
    // Send Start Bit
    GPIO_WriteBit(UART_GPIO, RX_Pin, Bit_RESET);
    delay_us(BRateTime);
```

```
for (unsigned char i = 0; i < 8; i++){
```

```
if( ((DataValue>>i)&0x1) == 0x1){
                    GPIO_WriteBit(UART_GPIO, RX_Pin, Bit_SET);
             } else{
                    GPIO_WriteBit(UART_GPIO, RX_Pin, Bit_RESET);
      delay_us(BRateTime);
      // Send Stop Bit
      GPIO_WriteBit(UART_GPIO, RX_Pin, Bit_SET);
       delay_us(BRateTime);
}
Data truyền đi sẽ được thêm bit parity tùy theo cấu hình parity bit là chẵn/lẻ hay không dùng
pairty bit:
typedef enum{
      Parity_Mode_NONE,
      Parity_Mode_ODD,
       Parity_Mode_EVENT
}Parity_Mode;
Có thể tạo bit parity bằng cách đếm số bit 1, sau đó thêm vào cuối chuỗi bit bit 0 hoặc 1
tương ứng:
uint8_t Parity_Generate(uint8_t data, Parity_Mode Mode){
       uint8_t count =0;
      for(int i=0; i<8; i++){
             if(data & 0x01){
                    count++;
             data >>=1;
      switch(Mode){
             case Parity_Mode_NONE:
                    return data;
                    break;
```

## 7.2.4.Hàm nhận:

Hàm nhận sẽ nhận lần lượt nhân 8 bit.

- Nếu baud=9600 chẳng hạn, thì thời gian của bit data = 104 us. Ta không cần thiết phải đọc dữ liệu ngay khi có tín hiệu đến. Do sườn lên và sườn xuống của xung data thường nhiễu. bởi vậy ta sẽ đọc ở vị chí chính giữa xung data.
- Chờ tín hiệu start từ thiết bị gửi (start bit: TX từ mức cao => mức thấp =0)
- Delay 1,5 period time (để đọc chính giữa bít xung data)
  - O Đọc data trên RX, ghi vào biến.
  - O Dich 1 bit.
  - O Delay 1 period time.
- Delay 0,5 period time và đợi stop bit (là bit keo từ mức 0->1: duy trì trong 1 thời gian dài).



```
uint8 t count =0;
      for(int i=0; i<8; i++){
             if(data & 0x01){
                   count++;
             data >>=1;
      switch(Mode){
             case Parity_Mode_NONE:
                   return 1;
                    break;
             case Parity_Mode_ODD:
                   return (count%2);
                    break;
             case Parity_Mode_EVENT:
                    return (!(count%2));
                   break;
             default:
                   return 0;
                    break;
}
#include "stm32f10x.h"
#include "stm32f10x_rcc.h"
#include "stm32f10x_gpio.h"
#include "stm32f10x_tim.h"
#define TX_Pin GPIO_Pin_9
#define RX_Pin GPIO_Pin_10
#define UART_GPIO GPIOA // set cổng ra USART Là GPIOA
#define BRateTime 104 // baudrate (9600 baud) = 9600 bit/s => delay truyen 1
bit = 104.16 us (làm tròn =104 us)
void RCC_Config() {
```

}

Sau khi nhân được data, có thể tiến hành kiểm tra chẵn/lẻ:

uint8\_t Parity\_Check(uint8\_t data, Parity\_Mode Mode){

//Cấp clock cho GPIOA, TIM2

```
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
RCC APB1PeriphClockCmd(RCC APB1Periph TIM2, ENABLE);
void GPIO Config() {
    //Cau hinh chan TX, RX cho GPIO,
    //RX nhân tín hiệu nên để mode: Input-floating, mode này không có điện trở
    //TX Truyền dữ liêu, chọn mode: Out_PP, Có điện trở kéo lên mức cao để tín
GPIO_InitTypeDef GPIOInitStruct;
GPIOInitStruct.GPIO_Pin = RX_Pin;
GPIOInitStruct.GPIO Mode = GPIO Mode IN FLOATING;
GPIO Init(UART GPIO, &GPIOInitStruct);
GPI0InitStruct.GPI0_Pin = TX_Pin;
GPIOInitStruct.GPIO Speed = GPIO Speed 50MHz;
GPI0InitStruct.GPI0 Mode = GPI0 Mode Out PP;
GPIO_Init(UART_GPIO, &GPIOInitStruct); //Nap cấu hình cho biến struct mới khai
void TIM Config() {
    //Cau hinh Timer
TIM_TimeBaseInitTypeDef TIM_InitStruct;
TIM InitStruct.TIM ClockDivision = TIM CKD DIV1;
    TIM_InitStruct.TIM_Prescaler = 72 - 1; // Cấu hình 1 us : Timer đếm lên 1
lần.
TIM InitStruct.TIM Period = 0xFFFF;
TIM_InitStruct.TIM_CounterMode = TIM_CounterMode_Up;
TIM_TimeBaseInit(TIM2, &TIM_InitStruct);
TIM Cmd(TIM2, ENABLE);
void delay_us(uint32_t time) {
    // Hàm delay thời gian micro second
TIM SetCounter(TIM2, 0);
while (TIM_GetCounter(TIM2) < time) {}</pre>
void clock() { //Ham tao xung chu kỳ = 104 us (tương đương 9600 baud)
delay_us(BRateTime); // = delay_us(104) = 104 us truyen 1 bit.
void UARTSoftware_Init() { // Ham set chế độ idle cho chân TX, lúc rảnh TX ở
GPIO_SetBits(GPIOA, TX_Pin);// Set TX_pin = 1.
delay us(1);
void UARTSoftware_Transmitt(char c) {
// Ham truyen data (char c)
GPIO_ResetBits(GPIOA, TX_Pin); // Keo chan TX xuong 0 cho bit bat dau, bat dau
truyen data.
clock(); // delay 104us
```

```
// Truyen 8 bit du lieu (tu LSB sang MSB)
for (int i = 0; i < 8; i++) {
   // Dùng mặt na Mask (1<<i):bx0000 00i0: vi trí thứ i, bit set lên 1. bit 1
lần lượt dịch từ bit LSB->MSB
   // Hàm điều kiên if(condition) = Nếu giá tri ở mức cao (1) thí set TX pin
lên 1, ngược lai reset TX pin về 0
   if (c & (1 << i)) {
GPIO_SetBits(GPIOA, TX_Pin); // Gui bit 1
} else {
GPIO_ResetBits(GPIOA, TX_Pin); // Gui bit 0
clock(); // Delay 104 us (9600 baud)
// stop bit- bit dung
GPIO SetBits(GPIOA, TX Pin); // Kéo chân TX lên mức cao =1 : stop bit
clock(); // Đơi thời gian 104 us để 1 thành bit stop.
char UARTSoftware_Receive() {
    // Ham nhan data
char c = 0;
   while (GPIO ReadInputDataBit(GPIOA, RX Pin) == 1); // wait Cho den khi
RX_pin = 0, thoat vong lap. (start bit =0)
// Cho 1.5 baudrate de lay mau du lieu chinh giua bit data, de tranh noise o
suon len va suon xuong cua bit
delay us(BRateTime + BRateTime / 2);
// Doc 8 bit du lieu (LSB truoc)
for (int i = 0; i < 8; i++) {
if (GPIO ReadInputDataBit(GPIOA, RX Pin)) {
    c = (1 \lt \lt i); // mask (1 \lt \lt i) : cho phep ghi bit thu i cua bien c len 1.
clock(); // Doi theo thoi gian cho bit tiep theo
// Cho bit dung (nno phai cao)
delay_us(BRateTime / 2); // Doi thoi gian 0.5 baudrate sau khi doc du lieu
return c;
char data[] = {'H','A','I'};
int main() {
RCC Config();
GPIO_Config();
TIM Config();
UARTSoftware_Init(); // set trang that idle cho chan TX
while (1) {
for (int i = 0; i < 3; i++) {
UARTSoftware_Transmitt(data[i]);
delay_us(1000);
```

```
char received = UARTSoftware_Receive();
UARTSoftware_Transmitt(received);
}
}
```

#### 7.3. Lập Trình trên UART Hardware

#### 7.3.1.Cấu hình GPIO

| I/O | FT | PA9  | USART1_TX <sup>(9)</sup> /<br>TIM1_CH2 <sup>(9)</sup> |
|-----|----|------|-------------------------------------------------------|
| I/O | FT | PA10 | USART1_RX <sup>(9)</sup> /<br>TIM1_CH3 <sup>(9)</sup> |

Các bộ UART trong STM32F1 được xác định sẵn các chân GPIO

Tương tự Software, TX sẽ là OUTPUT và RX sẽ là INPUT.

```
void GPIO_Config() {
    GPIO_InitTypeDef GPIO_InitStruct;
    // PA9 TX, mode: Alternative Function_Push Pull (chế độ cho usart,
spi,i2c)
    GPIO_InitStruct.GPIO_Mode = GPIO_Mode_AF_PP;
    GPIO_InitStruct.GPIO_Pin = GPIO_Pin_9;
    GPIO_InitStruct.GPIO_Speed = GPIO_Speed_50MHz;
    GPIO_Init(GPIOA, &GPIO_InitStruct);
    // PA10 RX, mode : thả nổi điện áp để nhận xung data
    GPIO_InitStruct.GPIO_Mode = GPIO_Mode_IN_FLOATING;
    GPIO_InitStruct.GPIO_Pin = GPIO_Pin_10;
    GPIO_Init(GPIOA, &GPIO_InitStruct);
}
```

### 1. Cấu hình UART

Tương tự các ngoại vi khác, các tham số Uart được cấu hình trong Struct USART\_InitTypeDef:

- USART\_Mode: Cấu hình chế độ hoạt động cho UART:
  - O USART\_Mode\_Rx: Cấu hình truyền.
  - O USART\_Mode\_Tx: Cấu hình nhận.
  - O Có thể cấu hình cả 2 cùng lúc.
- USART\_BaudRate: Cấu hình tốc độ baudrate cho uart.
- USART\_HardwareFlowControl: Cấu hình chế độ bắt tay cho uart.
- USART\_WordLength: Cấu hình số bit mỗi lần truyền.
- USART\_StopBits: Cấu hình số lượng stopbits.
- USART\_Parity: cấu hình bit kiểm tra chẳn, lẻ.

•

```
void UART_Config() {
    USART_InitTypeDef UART_InitStruct;
    UART_InitStruct.USART_BaudRate = 9600;
    UART_InitStruct.USART_HardwareFlowControl =
USART_HardwareFlowControl_None;
    UART_InitStruct.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; // Cau hinh
USART thuc hien ca truyen nhan
    UART_InitStruct.USART_Parity = USART_Parity_No;
    UART_InitStruct.USART_StopBits = USART_StopBits_1;
    UART_InitStruct.USART_WordLength = USART_WordLength_8b;
    USART_Init(USART1, &UART_InitStruct); // Luu cau hinh vao bien
    USART_Cmd(USART1, ENABLE); // Lenh cho USART1 Hoat dong
```

### USART InitTypeDef

```
49 typedef struct
 51 uint32_t USART_BaudRate;
                                        /*!< This member configures the USART communication baud rate.
                                               The band rate is computed using the following formula:

- IntegerDivider = ((PCLKx) / (16 * (USART_InitStruct->USART_BandRate)))

- FractionalDivider = ((IntegerDivider - ((u32) IntegerDivider)) * 16) + 0.5 */
 53
                                          /*!< Specifies the number of data bits transmitted or received in a frame.
This parameter can be a value of @ref USART_Word_Length */</pre>
 56 uintl6_t USART_WordLength;
 59 uintl6_t USART_StopBits;
                                         /*!< Specifies the number of stop bits transmitted.
This parameter can be a value of @ref USART_Stop_Bits */</pre>
 60
 62 uintl6_t USART_Parity;
                                          /*!< Specifies the parity mode.
                                               This parameter can be a value of @ref USART Parity
@note When parity is enabled, the computed parity is inserted
at the MSB position of the transmitted data (9th bit when
the word length is set to 9 data bits; 8th bit when the
 63
 65
                                                     word length is set to 8 data bits). */
 69 uintl6_t USART_Mode;
                                          /*!< Specifies wether the Receive or Transmit mode is enabled or disabled.
                                                This parameter can be a value of @ref USART Mode *,
 71 - 72 uintl6_t USART_HardwareFlowControl; /*!< Specifies wether the hardware flow control mode is enabled
                                                or disabled.
                                                This parameter can be a value of @ref USART Hardware Flow Control */
     ) USART_InitTypeDef;
120 /** @defgroup USART Word Length
121
        * @ {
122
123
124 #define USART WordLength 8b
                                                                              ((uint16 t)0x0000)
125 #define USART WordLength 9b
                                                                              ((uintl6 t)0x1000)
126
L27 ⊟ define IS USART WORD LENGTH(LENGTH) (((LENGTH) == USART WordLength 8b) | | \
128
                                                                   ((LENGTH) == USART WordLength 9b))
3 - /** @defgroup USART Stop Bits
4
        * @ {
5
6
7
    #define USART StopBits 1
                                                                              ((uint16_t)0x0000)
8 #define USART StopBits 0 5
                                                                              ((uint16_t)0x1000)
    #define USART StopBits 2
                                                                              ((uint16 t)0x2000)
0 | #define USART StopBits 1 5
                                                                              ((uint16 t)0x3000)
1 Data define IS USART STOPBITS (STOPBITS) (((STOPBITS) == USART StopBits 1) || \
                                                                 ((STOPBITS) == USART StopBits 0 5) || \
2
                                                                 ((STOPBITS) == USART StopBits 2) || \
3
                                                                 ((STOPBITS) == USART StopBits 1 5))
4
```

```
.74 -/** @defgroup USART Hardware Flow Control
.75
.76
      */
.77
    #define USART HardwareFlowControl None
                                                   ((uintl6 t)0x0000)
((uint16_t)0x0100)
.79  #define USART HardwareFlowControl CTS ((uint16_t)0x0200)
.80  #define USART HardwareFlowControl RTS CTS ((uint16_t)0x0300)
.81 | #define IS USART HARDWARE FLOW CONTROL (CONTROL) \
                                    __(((CONTROL) == USART_HardwareFlowControl_None) || \
.82 🗀
                                     ((CONTROL) == USART HardwareFlowControl RTS) || \
.83
.84
                                     ((CONTROL) == USART HardwareFlowControl CTS) || \
                                     ((CONTROL) == USART HardwareFlowControl RTS CTS))
.85
L49 ⊟ /** @defgroup USART Parity
150
       * @ {
151
152
153 #define USART Parity No
                                                          ((uintl6 t) 0x0000)
154 #define USART Parity Even
                                                         ((uint16 t)0x0400)
55 #define USART Parity Odd
                                                         ((uint16 t) 0x0600)
156 = #define IS USART PARITY(PARITY) (((PARITY) == USART Parity No) || \
                                           ((PARITY) == USART Parity Even) || \
157
                                            ((PARITY) == USART Parity Odd))
158
3 ⊟/** @defgroup USART Mode
55
6
7 | #define USART Mode Rx
                                           ((uint16_t)0x0004)
  #define USART Mode Tx
                                           ((uintl6 t)0x0008)
9 | #define IS USART MODE(MODE) ((((MODE) & (uintl6 t)0xFFF3) == 0x00) && ((MODE) != (uintl6 t)0x00))
```

Hàm USART\_SendData(USART\_TypeDef\* USARTx, uint16\_t Data), truyền data từ UARTx. Data này đã được thêm bit chẵn/lẻ tùy cấu hình.

Hàm USART\_ReceiveData(USART\_TypeDef\* USARTx), nhận data từ UARTx.

Hàm USART\_GetFlagStatus(USART\_TypeDef\* USARTx, uint16\_t USART\_FLAG) trả

về trạng thái cờ USART\_FLAG tương ứng:

- O **USART\_FLAG\_TXE**: Cờ truyền, set lên 1 nếu quá trình truyền hoàn tất.
- O **USART\_FLAG\_RXNE**: Cờ nhận, set lên 1 nếu quá trình nhận hoàn tất.
- O USART\_FLAG\_IDLE: Cờ báo đường truyền đang ở chế độ Idle.
- O USART\_FLAG\_PE: Cò báo lỗi Parity.

Quá trình truyền/nhân có thể mô tả như sau:

- Bắt đầu truyền/nhận, UART xóa hết data trong thanh ghi DR để đảm bảo data đúng.
- Truyền: Gửi đi từng byte data. Sau đó đợi cờ TXE bật lên.
- Nhận: Đọc data từ bộ UART, chò cò RNXE bật lên.
- Đối với mảng dữ liệu, lặp lại quá trình cho từng byte.

```
void UART_SendDataArray(USART_TypeDef* USARTx, uint8_t* data, uint8_t size)
{ // Creat ham truyen 1 mang data
    for (int i = 0; i < size; i++) {
    USART_SendData(USARTx, data[i]);
    while (USART_GetFlagStatus(USARTx, USART_FLAG_TXE) == RESET) {} // wait

den khi co bao truyen thanh cong Flag_TXE = 1 thi thoat vong lap
    delay_us(1000);
    }
    uint8_t UART_ReceiveByte(USART_TypeDef* USARTx) { // creat ham nhan

byte data
    while (USART_GetFlagStatus(USARTx, USART_FLAG_RXNE) == RESET) {}// wait

den khi co bao nhan thanh cong FLAG_RXNE =1, TH
    return USART_ReceiveData(USARTx);
    }
</pre>
```

Hàm truyền bit data thực chất là ghi vào thanh ghi DR, nhận bit Data là đọc từ thanh ghi DR

ra

```
591
     void USART SendData(USART TypeDef* USARTx, uintl6 t Data)
592 ⊟ {
593
      /* Check the parameters */
594
      assert param(IS USART ALL PERIPH(USARTx));
      assert_param(IS_USART_DATA(Data));
595
596
597
       /* Transmit Data */
      USARTx->DR = (Data & (uint16 t) 0x01FF);
598
599 }
600
601 ⊟/**
      * @brief Returns the most recent received data by the USARTx peripheral.
602
603
      * @param USARTx: Select the USART or the UART peripheral.
         This parameter can be one of the following values:
      * USART1, USART2, USART3, UART4 or UART5.
605
      * @retval The received data.
606
607 */
608 uintl6 t USART_ReceiveData(USART_TypeDef* USARTx)
609 ⊟ {
610
      /* Check the parameters */
      assert_param(IS_USART_ALL_PERIPH(USARTx));
611
612
       /* Receive Data */
613
614
      return (uintl6 t) (USARTx->DR & (uintl6 t) 0x01FF);
615
616
```